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BACKGROUND OF THE IISH^ENTTON 



1. Field of the Invention 

The present invention relates generally to computer software. More particularly, 
the present invention relates to network management software. 

2. Description of the Relevant Art 

The field of network management involves the management of networked 
devices, often remotely. A computer network is a linked group of two or more 
computers. Generally, networks may be classified as Local-Area Networks (LANs) or 
Wide-Area Networks (WANs). In a LAN, the computers or devices are typically 
connected together within a "local" area such as a home, office, or group of offices. In a 
WAN, the computers or devices are typically separated by a greater distance and are often 
connected via telephone/communication lines, radio waves, or other suitable means of 
connection. 

Networks are usually classified using three properties: topology, protocol, and 
architecture. Topology specifies the geometric arrangement of the network. Common 
topologies are bus, ring, and star configurations. A network's protocol specifies a 
common set of rules and/or signals, such as Ethernet or Token Ring, that the networked 
devices use to communicate with each other. A network 's architecture typically specifies 
one of the two major types of network architecture: peer-to-peer or client/server. In a 
peer-to-peer networking configuration, there is no server, and computers simply connect 
with each other in a workgroup to share files, printers, services, and Internet access. 
Client/server networks often include a domain controller to which all of the networked 
computers log on. This server may provide various services such as centrally routed 
Internet access, e-mail, file sharing, printer access, and security services. 
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Many types of devices may be managed over a network, such as printers, 
scanners, phone systems, copiers, and many other devices and apphances configured for 
network operation. Managing such devices tends to nsquire that the data types of each 
device's control parameters and signals be well defined. For example, a networked 
5 printer might have a Boolean status parameter that indicates whether the device is 
currently on or off and a control parameter which turns the printer on or off. The printer 
may also be capable of generating an alert signal indicating, for example, that the toner 
level is low. The network management software should be able to read and write these 
data correctly in order to manage the device. To do this, information about the data is 

10 required. Such information is referred to as metadata, or "data about data." Metadata 
may typically describe what type of data (string, integer, Boolean, structure) an object has 
and how the data are formatted. Metadata is essential for understanding information 
related to managed devices, as well as information stored in data warehouses. Typically, 
network management software manages a given devic(2 by storing and manipulating a 

15 representation of its pertinent data as a software object, herein referred to as a "managed 
object." This object is the virtual representation of the device on the network. 

Figure la illustrates an example of typical elements of a telecommunications 
network. The telecommunications world is characterized by devices such as cell phones, 

20 cell phone towers and other kinds of towers 156, phone systems 151, faxes 152, routers 
153, switches 154, satellite dishes 155, etc., which may be interconnected via networks 
108a. In response to the network management needs of this technology sector, a 
conceptual firamework for telecom network management called Telecommunications 
Management Network (TMN) was developed by the leleManagement Forum (TMF). 

25 TMN defines the relationship between basic network building blocks, such as network 
elements, different network protocols, and operations systems, in terms of standard 
interfaces. Generally, a TMN system includes Agent hardware 150, Manager software 
170, and Agent software 160. The Agent hardware 150 includes the managed devices 
such as those shown in Figure la. The Manager software 170 includes any application 

30 used to manage a networked device. These manager appilications, or client applications, 
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may be installed and executed on one or more client computer systems 171a, 171b, . . . , 
17 In. The Agent software 160 includes the software interface between the Manager 
software 170 (for communications via network 108b) and the Agent hardware 150 (for 
communications via network 108a). The Agent software 160 may be installed and 
5 executed on one or more server computer systems 161a, 161b, . . . , 161n, hi some 
instances, the Agent software 160 and Manager soflware 170 may be installed and 
executed on the same computer system. The Agent software 160 may also reside, in 
whole or part, on the Agent hardware 150 itself 

10 One TMN approach to managing objects over a network is the Simple Network 

Management Protocol (SNMP), a set of protocols for managing complex networks. 
SNMP works by sending messages, called protocol data units (PDUs), to different parts 
of a network. SNMP-compliant devices, called agents, store data about themselves in 
Management Information Bases (MIBs) and return this data to the SNMP requesters. The 

15 metadata used by SNMP to describe managed object data variables includes the variable 
title, the data type of the variable (e.g. integer, string), whether the variable is read-only 
or read-write, and the value of the variable. SNMP works over the TCP/IP (Transport 
Control Protocol/ Internet Protocol) communication stack. SNMP also uses UDP over 
IP, and also may support TCP over IP. It is widely held, however, that SNMP was 

20 developed as a simple "quick fix" and was never intended to be a permanent solution to 
network management. Consequently, one problem with SNMP is that the information it 
specifies is neither detailed nor well-organized enough to adequately serve the expanding 
needs of modem networking. 

25 Another example of a TMN network management protocol is the Common 

Management Information Protocol (CMIP). In the U.S. the CMIP protocol is primarily 
run over TCP/IP, while in Europe it is generally run over the OSI (Open Systems 
Interconnection) communication stack and was designed to replace SNMP and address 
SNMP's shortcomings by providing a larger, more detailed network manager. Its basic 

30 design is similar to SNMP: Management requests, management responses, and 
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notifications are employed to monitor a network. These correspond to SNMP's PDUs. 
CMIPj however, contains eleven types of messages, compared to SNMP's five types of 
PDUs. 

5 In CMIP, variables are seen as complex and sophisticated data structures with 

many attributes. These include: variable attributes, which represent the variable's 
characteristics (e.g., its data type, whether it is writable); variable behaviors, or the 
actions of that variable that can be triggered; and notifications, or event reports generated 
by the variable whenever a specified event occurs (e.g., a terminal shutdown would cause 
10 a variable notification event). 

As a comparison, SNMP only employs variable attributes and notifications, but 
not variable behaviors. One of the strongest features of the CMIP protocol is that its 
variables not only relay information to and fl-om the tenninal (as in SNMP), but they can 

15 also be used to perform tasks that would be impossible xmder SNMP. For instance, if a 
terminal on a network cannot reach its fileserver for a predetermined number of tries, then 
CMIP can notify the appropriate personnel of the event. With SNMP, a user would need 
to explicitly keep track of the number of unsuccessfixl attempts to reach the fileserver, 
CMIP thus results in a more efficient network management system, as less work is 

20 required by a user to keep updated on the status of the network. 

A significant disadvantage of the CMIP protocol is that it requires more system 
resources than SNMP, often by a factor of ten. Thus, ^my move to CMIP fi-om SNMP 
requires a dramatic upgrade in network resources. Another disadvantage with CMIP is 
25 that it is very difficult to program; the variable metadata includes so many different 
components that few programmers are generally able to use the variables to their ftill 
potential. 

Both of the above protocols have been implemented in a number of programming 
30 languages, such as C, C-H-, and Java™. However, network management software which 
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takes advantage of SNMP or CMIP must be written specifically for the language of the 
protocol implementation. In other words, SNMP-based and CMIP-based network 
management software is dependent upon a particular programming language and protocol 
implementation. 

5 

A middleware standard used extensively in network management is the Common 
Object Request Broker Architecture (CORBA), which is provided by the Object 
Management Group (OMG). COJ^A specifies a system that provides interoperability 
between objects in a heterogeneous, distributed environment and in a way transparent to 
10 the programmer. Its design is based on the OMG Object Model, which defines common 
object semantics for specifying the externally visible characteristics of objects in a 
standard and implementation-independent way. In this model, clients request services 
firom objects (which will also be called servers) through a well-defined interface. This 
interface is specified in the OMG Interface Definition Language (IDL). 

15 

In CORBA, a cKent accesses an object by issuiing a request to the object. The 
request is an event, and it carries information including an operation, the object reference 
of the service provider, and actual parameters, if any. The object reference is an object 
name that reliably defines an object. 

20 

A central component of CORBA is the Object Ri^quest Broker (ORB). The ORB 
encompasses the communication infi^astructure necessary to identify and locate objects, 
handle connection management, and deliver data. In general, the ORB is not required to 
be a single component; it is simply defined by its interfaces. The basic fiuictionality 

25 provided by the ORB includes passing the requests fi-om chents to the object 
implementations on which they are invoked. The ORB acts as the middleware between 
clients and servers. In the CORBA model, a client can request a service without knowing 
anything about what servers are attached to the network. The various ORBs receive the 
requests, forward them to the appropriate servers, and then hand the results back to the 

30 client. 
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In CORBA, a client first looks up the object (server) it wants to communicate 
5 with. The ORB, as a result of the lookup operation, returns an object reference (a handle) 
of the server to the client. The chent then uses the object reference to invoke operations 
on the object as a function call in the chosen programming language. The ORB intercepts 
the client request, collects the information about the operation and the request parameter 
values, encodes it in HOP, and sends it to the object (seiver). The ORB on the object side 
10 (server) translates the request into a programming language specific function call on the 
server object. The server object then processes the request and returns a response, if any. 
The ORB intercepts the response, encodes the response and its parameters into HOP, and 
sends it to the chent. The ORB on the client side then retxmis the response to the client as 
the return value of the fiinction call originally made as p art of issuing the request. 

15 

GDMO (Guidelines for Definition of Managed Objects) is a standard for defining 
objects in a network in a consistent way. With a consistent "language" for describing 
such objects as workstations, LAN servers, and switches, programs can be written to 
control or sense the status of network elements throughout a network, GDMO prescribes 
20 how a network product manufacturer must describe the product formally so that others 
can write programs that recognize and deal with the product. Using GDMO with ASNl , 
descriptions may be made of the class or classes of the object, how the object behaves, its 
attributes, and classes that it may inherit. 

25 GDMO is part of the CMIP and also the guideline for defining network objects 

under TMN. The object definitions created using GDMO and related tools form a 
Management Information Base (MIB). GDMO uses Abstract Syntax Notation One 
(ASNl) as the rules for syntax and attribute encoding when defining the objects. 
Abstract Syntax Notation One is a language that defines the way data is sent across 

30 dissimilar communication systems. ASNl ensures that the data received is the same as 
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the data transmitted by providing a common syntax for specifying application layer (e.g., 
program-to-program conrninnications) protocols. Each communications system contains 
a similar ASNl encoding/decoding scheme written in tlie language used on that particular 
system. When one system wants to send data to another, the first system encodes the data 
5 into ASNl, sends the data, and the second system receives and decodes the data using the 
decoder written in the language used on that system. 

In response to the difficulties presented by SNMP and CMIP, the Object 
Management Group (OMG) and Joint Inter-Domain Management (JIDM) have defined 

10 Interface Definition Language (IDL) for network management, which is used to access 
object instance data and may be used across a plurality of programming languages and 
across a plurality of platforms. JIDM IDL allows progjrammers to write only one set of 
interfaces for a particular object across multiple pro§p:amming languages, rather than 
having to write a new set of interfaces for each programming language. Although the use 

15 of IDL as a programming-language-independent and platform-independent interface to 
define CORBA services and objects greatly improves the ease with which network 
objects may be managed, there is a significant problem in that for each TMN object to be 
managed, an IDL interface must be defined and compiled. This problem leads to a great 
proliferation of object interfaces which must be learned to manage the network 

20 effectively. The management of such a large number of compiled object-specific 
interfaces requires significant memory and disk space resources and degrades the 
performance and scalability of management applications. Whenever a new object type is 
to be added to a network, the system must be shut down and recompiled with the new 
object interface. With the great number of object interfaces involved, compile times may 

25 be exceedingly long. Because many network management systems, especially in the field 
of telecommunications network management, are expected to be operable continuously 
with no downtime, adding or removing managed object types may become problematic. 

Therefore, improved systems and methods for managing network devices are 
30 desired. 
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SUMMARY OF THE INVENTION 



The problems outlined above are in large part solved by various embodiments of a 
system and method for generic and dynamic mapping of managed object metadata as 
disclosed herein. In one embodiment, an IDL type may be mapped to a corresponding 
ASNl type. The data to be mapped may include type information about an attribute, 
action, or notification of a managed object. The first data type may be entered into the 
mapping system, then the corresponding second data type may be determined. In one 
embodiment, determining the corresponding second data type may be accomplished via a 
lookup table. Finally, the second data type may be retumed. In this maimer, data types 
related to the attributes, events, or other parameters of managed objects may be converted 
between various data description languages, such as OMG IDL and ASNL 

In one embodiment, one of the data types may be represented in a generic 
interface description language which is operable to describe interfaces to managed objects 
across a plurality of platforms and across a plurality o F programming languages, and is 
class independent. As used herein, the term "class independent" refers to the property 
that a single interface may be defined to describe substantially all data types and all 
managed objects. Given the number of different types <3f TMN objects one may need to 
manage on a network, having a single object interface for all of them saves significant 
resources in that there is no need to statically compile and store separate interfaces for the 
many objects, which may increase the scalability of a network management system 
dramatically. This also means that one may add a new object to the system without 
bringing the system down to compile a new interface, nriaking it much easier to maintain 
system operations with little or no downtime. 

In one embodiment, the first data type may be: a complex object data type in 
GDMO/ASNl, which may be mapped to a sequence of a generic primitive data type in 
DDL, such as the <any> data type. As another example, the complex ASNl object data 
type may be mapped to a choice structure in IDL, where the choice structure includes a 
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generic value field (<any>), a plurality of data types, Jind a selector index, whereby the 
appropriate data type of the generic value may be detemiined. Alternately, the converse 
of the above mappings may be performed. 

5 In one embodiment, an IDL-ASNl converter iramework library in conjunction 

with a converter implementation library may provide a suitable system for managed 
object data type conversions between various data description languages. In one 
embodiment, when a CORBA cUent apphcation invokes a management request on a 
Request Gateway, the Gateway may convert the request parameter values in IDL data 

10 types to PMFs ASNl Values. PMI (Portable Management Interface) is a proprietary C++ 
API that is used in developing C++ management and agent appUcations (managers and 
agents). Similarly, when the Gateway receives a response from an enterprise manager, it 
may convert the response parameter values in PMFs ASNl Values to values in IDL data 
types. This conversion facility may be used extensively in both request and event 

15 network traffic, and so in one embodiment, common libraries may be used. 

In one embodiment, the framework library provides a collection of classes that 
may be used by the clients of the converter libraries,. Most classes in the converter 
framework library are handle classes (or wrappers) to ttie real implementation (or body) 
20 classes in the converter implementation library. Frame\^^ork classes hide the details of the 
real implementation classes and provide a simple, consistent interface to any data type 
converter. 

In one embodiment, an IDLValue class is a data-liolder used to hold IDL values in 
25 CORBA:: Any, the CORBA generic data type. Therefore, only one interface may be used 
for converting any data type. The use of a single generic primitive data type, along with 
the simple container types of set and sequence, provides an efficient, simple approach to 
managing managed object metadata across multiple platforms and multiple programming 
languages, in addition to providing a generic interface to all managed object classes. 
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Consider the conversion process for a complex data type, such as the ASNl SET 
OF type. To convert an attribute whose ASNl type is SET OF INTEGER, ASNl SET 
OF is mapped to IDL sequence<any>. The 'any' in the sequence contains the IDL 
integer. When the user wants to convert values from IDL sequence<any> to ASNl SET 
5 OF INTEGER, a generic converter method may be invoked. This method, in turn, may 
invoke the ASNl sequence-specific implementation converter method. Since ASNl 
SETOF is a constructed type, it may get the contained t^^e. From that type, it may create 
a generic converter for the contained type. The;n the ASNl sequence-specific 
implementation converter method may invoke the generic converter method on the 

10 contained type. Since the contained type happens to l^e a simple type INTEGER, this 
method may eventually invoke the ASNl integer converter method on the indexed 
element of the sequence. The integer converter is operable to convert values to ASNl, at 
which point recursion ends. The other complex types typically use the same pattern as 
described above, using recursive invocations of convi^rt methods on the contained or 

1 5 referred types until the simple types are reached. 

The combination of using IDL and the generic type <any> provides an efficient, 
generic solution to mapping data types across multiple platforms, multiple programming 
languages, and multiple object classes. 

20 
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BRIEF DESCRIPTION OF THE DRAWINGS 



Other objects and advantages of the invention will become apparent upon reading 
the following detailed description and upon reference to the accompanying drawings in 
which: 

Fig. la illustrates an example of typical elements of a telecommunications 
network. 

Fig. lb is an illustration of a typical computer system architectiire which is 
suitable for implementing various embodiments. 

Fig. 2 is an illustration of a CORBA gateway to an enterprise manager according 
to one embodiment. 

Fig. 3 is a flowchart illustrating mapping from a first data type to a second data 
type according to one embodiment. 

Fig. 4 is an object inheritance diagram of an :[DL-ASN1 Converter Framework 
according to one embodiment. 

Fig. 5 is a diagram of an IDL-ASNl Converter Framework with Converter 
Modules according to one embodiment. 

While the invention is susceptible to various modifications and alternative forms, 
specific embodiments thereof are shown by way of example in the drawings and will 
herein be described in detail. It should be understood, however, that the drawing and 
detailed description thereto are not intended to limit the invention to the particular form 
disclosed, but on the contrary, the intention is to cover all modifications, equivalents and 
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alternatives falling within the spirit and scope of the present invention as defined by the 
appended claims. 
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DETAILED DESCRIPTION OF SEVEIUL EMBODIMENTS 



Figure lb: A Typical Computer System 

Turning now to the drawings, Fig. lb is an illustration of a typical, general- 
purpose computer system 100 which is suitable for implementing various embodiments 
of the system and method for network management as disclosed herein. The computer 
system 100 includes at least one central processing unit (CPU) or processor 102. The 
CPU 102 is coupled to a memory 104 and a read-only memory (ROM) 106. The memory 
104 is representative of various types of possible memory media: for example, hard disk 
storage, floppy disk storage, removable disk storage, or random access memory (RAM). 
The terms "memory," "memory medium," and "storage medium" may include an 
installation medium, e.g., a CD-ROM or floppy disk, a computer system memory such as 
DRAM, SRAM, EDO RAM, etc., or a non-volatile memory such as a magnetic media, e.g., 
a hard drive or optical storage. The memory mediiun raay include other types of memory 
as well, or combinations thereof In addition, the memo;ry medium may be located in a first 
computer in which the programs are executed, or may be located in a second different 
computer which connects to the first computer over a network. In the latter instance, the 
second computer provides the program instructions to the first computer for execution. 

As shown in Fig. lb, typically the memory 104 permits two-way access: it is 
readable and writable. The ROM 106, on the other hand, is readable but not writable. 
The memory 104 and/or ROM 106 may store instructions and/or data which implement 
all or part of the system and method described in detail herein, and the memory 104 
and/or ROM 106 may be utilized to install the instructions and/or data. In various 
embodiments, the computer system 100 may take vaiious forms, including a personal 
computer system, desktop computer, laptop computer, pahntop computer, mainframe 
computer system, workstation, network appliance, netwwk computer, Internet appHance, 
personal digital assistant (PDA), embedded device, smart, phone, television system, or other 
suitable device, hi general, the term "computer system" can be broadly defmed to 
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encompass any device having a processor which execuites instructions from a memory 
medium. 

The CPU 102 may be coupled to a network 108. The network 108 is 
representative of various types of possible networks: for example, a local area network 
(LAN), wide area network (WAN), or the Internet. The system and method for network 
management as disclosed herein may therefore be implemented on a pluraHty of 
heterogeneous or homogeneous networked computer s)^stems 100 through one or more 
networks 108. The CPU 102 may acquire instructions and/or data for implementing 
system and method for network management as disclosed herein over the network 108. 

Through an input/output bus 110, the CPU 102 irnay also coupled to one or more 
input/output devices that may include, but are not limited to, video monitors or other 
displays, track balls, mice, keyboards, microphones, touch-sensitive displays, magnetic or 
paper tape readers, tablets, styluses, voice recognizers, handwriting recognizers, printers, 
plotters, scanners, and any other devices for input and/or output. The CPU 102 may 
acquire instructions and/or data for implementing the system and method for network 
management as disclosed herein through the input/output bus 1 10. 

The computer system 100 is operable to execute one or more computer programs. 
The computer programs may comprise operating system or other system software, 
application software, utility software, Java™ applets, and/or any other sequence of 
instructions. Typically, an operating system performs basic tasks such as recognizing 
input from the keyboard, sending output to the display screen, keeping track of files and 
directories on the disk, and controlling peripheral devices such as disk drives and printers. 
AppHcation software runs on top of the operating system and provides additional 
fimctionality. Because applications take advantage of services offered by operating 
systems, and because operating systems differ in the services they offer and in the way 
they offer the services, an appHcation must usually be designed to run on a particular 
operating system. The computer programs are stored in a memory medium or storage 
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medium such as the memory 104 and/or ROM 106, or they may be provided to the CPU 
102 through the network 108 or I/O bus 1 10. 

In one embodiment, the computer programs executable by the computer system 
5 100 may be implemented in an object-oriented progjamming language. In an object- 
oriented programming language, data and related methods can be grouped together or 
encapsulated to form an entity known as an object. All objects in an object-oriented 
programming system belong to a class, which can be thought of as a category of like 
objects which describes the characteristics of those objects. Each object is created as an 

10 instance of the class by a program. The objects may therefore be said to have been 
instantiated from the class. The class sets out variables and methods for objects which 
belong to that class. The definition of the class does not itself create any objects. The 
class may define initial values for its variables, and it normally defines the methods 
associated with the class (i.e., includes the program code which is executed when a 

15 method is invoked.) The class may thereby provide all of the program code which will be 
used by objects in the class, hence maximizing re-use of code which is shared by objects 
in the class. 

Figure 2: CORBA Gateway 

20 

Figure 2 illustrates a CORBA gateway from CORBA-based appUcations to an 
enterprise manager according to one embodiment. In one embodiment, the system may 
be configurable to manage various networked objects, such as printers, scanners, phone 
systems, copiers, and many other devices and appliances configured for network 

25 operation. For purposes of simplicity, similar components, e.g., manager applications 
206a and 206b, may be referred to collectively herein by a single reference numeral, e.g., 
206. As shovra in Figure 2, CORBA-based TMN manager applications 206 may be 
communicatively coupled to a CORBA Object Request Broker (ORB) 202. The manager 
applications 206 may be operable to send Interface Definition Language (IDL) requests 

30 214 and receive IDL responses and CORBA events 216 through the CORBA ORB 202. 
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A CORBA gateway 208 may also be communicatively coupled to the CORBA ORB 202 
and be operable to communicate with the CORBA ORB 202 via communications 
methods 218 such as the Internet Inter-Object Protocol ([lOP), also known as the Internet 
Inter-ORB Protocol, and IDL. IIOP is a protocol developed by the Object Management 
Group (OMG) to implement CORBA solutions over the World Wide Web. Unlike 
HTTP, IIOP enables browsers and servers to exchange integers, arrays, and more 
complex objects. 

In one embodiment, an enterprise manager 212 may be coupled to the CORBA 
gateway 208 via a proprietary or platform-dependent interface such as Portable 
Management Interface (PMI) 220 from Sun Microsystems, Inc. The enterprise manager 
212 may include various enterprise management components such as a Management 
Information System (MIS), etc. Also coupled to the enterprise manager 212 via PMI 220 
may be one or more PMI applications 210. PMI appUcations may include, for example, 
appUcations which provide access to event notification, subscription, and propagation 
services and access to object instance information. In one embodiment, the enterprise 
manager 212 may be Solstice Enterprise Manager (SElVl) from Sun Microsystems, Inc., 
and examples of the one or more PMI applications 210 that use PMI to communicate with 
the SEM MIS may include SEM Viewer, SEM Alarm Manager, SEM Discovery, etc. In 
one embodiment, the CORBA gateway 208 may translate the CORBA manager requests 
214 from IDL to PMI requests 220. Similarly, the CORBA gateway 208 may translate 
the enterprise manager PMI responses and PMI events 220 to IDL/IIOP responses and 
events 218 which may be passed on through the CORBA ORB 202 to the manager 
appUcations 206 in the form of IDL responses and CORBA events 216. 

In one embodiment, manager applications 206 may request information regarding 
managed objects on the network via the CORBA Gateway 208. The managed objects 
may represent devices such as cell phones, cell phone towers, phone systems, faxes, 
routers, switches, etc., which may be interconnected via networks. The data related to 
such objects may exist in a variety of formats, and so must be translated to forms readily 

Attorney Docket No.: 5181-46100 Pagel7 Conley, Rose & Tayon, P.C. 



understood by the manager applications 206. This function may be performed by a 
component of the CORBA Gateway 208. More specifically, a mapping system may be 
invoked by the CORBA Gateway 208 to translate managed object data and metadata 
between various data formats, such as OMG IDL and ASNl. 

Figure 3: Mapping From A First Data Type To A Second Data Type 

In one embodiment, a converter framework may provide a suitable system for 
managed object data type conversions between variious data description languages in 
support of communication between the CORBA Gateway 208 and an enterprise manager 
212. For example, when a manager application 212 initiates a request on the CORBA 
Gateway 208, the Gateway 208 may convert the request parameter values in IDL data 
types to PMFs ASNl Values. Similarly, when the Gateway 208 receives a response from 
an enterprise manager 212, it may convert the response parameter values in PMFs 
ASNl Values to values in IDL data types. 

Figure 3 illustrates the steps involved in mapping a first data type to a second data 
type according to one embodiment. For example, an IDL integer type may be mapped to 
a corresponding ASNl integer type. In one embodiment, this mapping may be enabled 
by a converter framework. In one embodiment, the data to be mapped may include type 
information about an attribute, action, or notification of a managed object. In step 302, 
the first data type is entered into the mapping systemi. In step 304, the corresponding 
second data type is determined. In one embodiment, determining the corresponding 
second data type may be accomplished via a lookup table. Finally, in step 306, the 
second data type is returned. In this manner, data types related to the attributes, events, or 
other parameters of managed objects may be converted between various data description 
languages, such as OMG IDL and ASNl. 

In one embodiment, one of the data types is represented in a generic interface 
description language which is operable to describe interfaces to managed objects across a 
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plurality of platforms and across a plurality of progriamming languages, and is class 
independent. As used herein, the term "class independent" refers to the property that a 
single interface may be defined to describe substantially all data types and all managed 
objects. The benefits of having a generic interface to managed object data types are 

5 substantial. Given the number of different types of TMN objects one may need to 
manage on a network, having a single object interface for all of them saves significant 
resources in that there is no need to statically compile and store separate interfaces for the 
many objects, which may increase the scalability of a network management system 
dramatically. This also means that one may add a new object to the system without 

10 bringing the system down to compile a new interface, raaking it much easier to maintain 
system operations with little or no downtime. 

For example, the first data type may be a complex object data type in 
GDMO/ASNl, which may be mapped to a sequence of a generic primitive data type in 
15 IDL, such as the <any> data type. As another example, the complex ASNl object data 
type may be mapped to a choice structure in IDL, where the choice stracture includes a 
generic value field (<any>), a plurality of data types, md a selector index, whereby the 
appropriate data type of the generic value may be deteimined. Alternately, the converse 
of the above mappings may be performed. 

20 

Figure 4: IDL-ASNl Converter Framework Object Inheritance Diagram 

Figure 4 illustrates IDL-ASNl converter firamework object inheritance according 
to one embodiment. This framework may provide a suitable system for managed object 

25 data type conversions between various data description languages. In one embodiment, 
when a CORBA cUent application 206 invokes a management request on the Gateway 
208, the Gateway 208 may convert the request parameter values in IDL data types to 
PMI's ASNlValues. Similarly, when the Gateway 208 receives a response from an 
enterprise manager, it may convert the response parameter values in PMI's ASNlValues 

30 to values in IDL data types. This conversion facility may be used extensively in both 
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request and event network traffic, and so in one embodiment, common libraries may be 
used. 

Because there is potential for different mappings of IDL data types to ASNl data 
5 types, in one embodiment, two separate libraries may be used: a converter framework 
library and a converter implementation library. The use of converter implementation 
libraries may allow various different mappings to be used easily by implementing them as 
plug-in modules. In one embodiment, the two libraries may include an ASNl converter 
framework library 450 and a C++ IDL- ASNl converter implementation library 460. The 
10 added benefit of this approach is that the converter framework library 450 can be reused 
to support conversion of ASNl types and values to other formats like TL-1, simply by 
providing an appropriate converter implementation library corresponding to the IDL- 
ASNl converter implementation library 460. 

15 In one embodiment, the converter framework and converter implementation may 

be designed as multi-threaded programs. The term "multi-threaded" means that various 
processes, or threads, of a program may execute concurrently. In one embodiment, this 
feature is accommodated by the operating system under which the program runs. 

20 Converter Framework Library 

In one embodiment, the framework library 450 is essentially a collection of 
classes that may be used by the clients of the converter libraries. Most classes in the 
converter framework library are handle classes (or wrappers) to the real implementation 
(or body) classes in the converter implementation library 460. Framework classes hide 

25 the details of the real implementation classes and provide a simple, consistent interface to 
any data type converter. 

Referring to Figure 4, RCObject 402 is the base class for all other classes in the 
system in one embodiment. RCObject 402 may provide a reference-counting capability, 
30 and any real (implementation) converters are preferably inherited from this class. As 
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Figure 4 shows, the framework classes which inherit directly from RCObject 402 are the 
AbstractASNlConverterlmpl 412 and the GenericASNlConverterHelper 406, Note that 
AbstractASNlConverterlmpl 412 also inherits from AbstractASNl Converter 404, as 
does GenericASNl Converter 408, which uses GenericASNlConverterHelper 406. The 
5 AbstractASNl Converter class 404 is intended to be an interface class and hence is an 
abstract class, i.e., no concrete instance of this class may exist. Similarly, OpaqueValue 
410 is intended to be an interface class with no concrete instantiations. OpaqueValue 410 
is a data-holder for data of any type. 

10 For example, in one embodiment, C++ IDL<->ASN1 converters may create a 

class IDL Value 416, subclass of OpaqueValue 410, to hold C++ IDL data. In an alternate 
embodiment, TL1<-->ASN1 converters could define their own subclasses to hold data 
specific to that domain. 

15 In one embodiment, AbstractASNlConverterlmpl 412 is an abstract base class to 

be inherited by the real (implementation) converters. GenericASNl Converter 408 is a 
concrete class that is used primarily by clients of the converter libraries. Generally, users 
do not need to know the exact converter they are dealing with. Instead, they may use 
GenericASNl Converter to convert values to and from ASNl format through IDL. 

20 GenericASNl Converters are typically created per registered attribute or event or action 
types. GenericASNl Converters may also be created for non-registered types (or types 
that may not have an Object ID). Primarily, their usage is restricted to the converter 
library implementation. 

25 GenericASNl Converter 408 constructors may act like virtual constructors. 

Based on an Object ED or type, they may use GenericAiSNlConverterHelper 406 to create 
the real converter. That is, the helper may help the framework create the actual 
converters (such as Boolean converters, etc.). GenericASNlConverterHelper 406 may 
provide a method to create an appropriate converter based on the ASNlType it receives. 

30 
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Note that GenericASNlConverterHelper 406 may be an abstract base class to be 
implemented by the real converter library. The implementation helper may help create 
real converters based on the ASNlType. When one of the GenericASNl Converter 408 
constructors is invoked, GenericASNl Converter 408 may invoke a type lookup method, 
5 if necessary, to get the relevant ASNlType object. Then, GenericASNl Converter 408 
may invoke a GenericASNlConverterHelper 406 method to create the actual converter 
corresponding to that ASNlType object. The actual converter is then used to convert the 
data type. 

10 Converter Implementation Library 

Referring to Figure 4, the converter implementation library 460 preferably 
provides the implementation needed by the framework to function properly. In one 
embodiment, the converter implementation library is operable to convert data types 
between IDL and ASNl types. Users of converters typically do not interact directly with 

15 the converter implementation library 460. Instead, as described above, they use the 
GenericASNl Converter class 408 of the converter framework. The converter 
implementation library 460 may provide various data type converters. The design of each 
of these converters is similar. 

20 As shown in Figure 4 and described above, the IDLValue class 416 may be 

derived from the generic type class OpaqueValue 410, and the 
GenericASNl ConverterHelperlmpl 414 helper class ruay be derived from the abstract 
GenericASNlConverterHelper 406 class, according to one embodiment. Furthermore, 
each of the type converter implementation classes may be derived from the 

25 AbstractASNlConverterlmpl 412 class, as well as from each converter's specific ANSI 
type class. For example, ASNlIntegerConverter 431 may be derived from the 
AbsfractASNlConverterlmpl class 412, as well as the ASNlTypeInt class 421, 
according to one embodiment. 
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As mentioned above, IDL Value class 416 is a data-holder used to hold IDL values 
in CORBA::Any, the CORBA generic data type. Therefore, only one interface may be 
used for converting any data type. IDLValue class does not have any significance other 
than to hold the IDL data and provide a uniform interface. CORBA:: Any 's copy 
5 constructor and assignment operator use deep-copy semantics, thus making it prohibitive 
to use a non-reference (non-pointer) member. The use of a single generic primitive data 
type, along with the simple container types of set and sequence, provides an efficient, 
simple approach to managing managed object metadata across multiple platforms and 
multiple programming languages. 

10 

In one embodiment, Generic ASNlConverterHelperlmpl 414 may provide the 
implementation of GenericASNlConverterHelper 406 abstract base class. 
GenericASNlConverterHelperlmpl 414 may generate the particular converters used by 
the client. For example, in one embodiment, ASNlIntegerConverter 431 is an actual 

15 converter that is capable of converting values between ASNl INTEGER and IDL 
INTEGER types. The user typically creates a GenericASNl Converter 408 for, say, an 
INTEGER attribute. GenericASNl Converter 408 will utilize 

GenericASNlConverterHelper 406 to create the ASNlIntegerConverter 431 object. 
Then the user may invoke the relevant convert method of GenericASNl Converter 408. 

20 GenericASNl Converter 408, in turn, may delegate that request to ASNlIntegerConverter 
431. Note that ASNlIntegerConverter 431 cannot be created on the stack. It must be 
created on the heap because it is a reference counted object, and therefore, the create 
method is static. 

25 Consider the conversion process for a complex data type, such as the ASNl SET 

OF type. For example, to convert an attribute whose ASNl type is SET OF INTEGER, 
the user typically creates the GenericASNl Converter 408 for this attribute. ASNl SET 
OF is mapped to IDL sequence<any>. The 'any' in the sequence contains the IDL 
integer. When the user wants to convert values from EDL sequence<any> to ASNl SET 

30 OF INTEGER, the GenericASNl Converter 408 converter method may be invoked. This 
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method, in turn, may invoke the ASNlSeqOfConverter converter method. Since ASNl 
SETOF is a constructed type, it may get the contained t/pc. From that type, it may create 
a GenericASNl Converter 408 (for the contained type). Then the ASNlSeqOfConverter 
converter method may invoke the GenericASNl Converter 408 converter method on the 

5 contained type. Since the contained type happens to be a simple type INTEGER, this 
method may eventually invoke the ASNlIntegerConverter 431 converter method on the 
indexed element of the sequence. The integer converter is operable to convert values to 
ASNl, at which point recursion ends. The other complex types typically use the same 
pattern as described above, using recursive invocations of convert methods on the 

10 contained or referred types imtil the simple types are reached. 

Figure 5: Converter Framework with Converter Module s 

Figure 5 illustrates a converter framework 508 and converter implementations 516 
15 which may respectively correspond to converter framework library 450 and converter 
implementation library 460 according to one embodiment. Converter implementations 
516 may include various converter modules 514a-514d. As Figure 5 shows, in one 
embodiment, a manager appUcation 206 (as shown in Figure 2) is communicatively 
coupled to the converter framework 508, via an interface definition language, such as IDL 
20 214. The converter framework 508 is coupled to the various converter modules 514a- 
514d of the converter implementations 516. The converter framework 508 is further 
coupled to an enterprise manager 212 (as shown in Figure 2), such as the Solstice 
Enterprise Manager™ (SEM) available from Sun Microsystems, Inc„ through an abstract 
syntax notation or other metadata notation language, such as ASNl 510. 

25 

In one embodiment, the converter modules 514a-514d are plug-in modules which 
are operable to plug into the converter framework 508, as discussed with reference to 
Figure 4. The converter modules 514a-514d may then provide various functional 
mappings of managed object metadata between the int<3rface definition language and the 
30 abstract syntax notation as invoked by the converter framework 508. In one embodiment. 
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each converter module 514a-514d may be operable to map managed object metadata 
types between IDL 214 and ASNl 510, according to that module's particular mapping. 
In an alternate embodiment, a converter module 514a-514d may map managed object 
metadata types between IDL and a transaction language, such as Transaction Language 
5 One (TL-1). 

The combination of using IDL and the generic lype <any> provides an efficient, 
generic solution to mapping data types across multiple ]platforms, multiple programming 
languages, and multiple object classes. The fact that the framework described herein may 
10 accommodate a variety of plug-in modules for mapping other data types to and from IDL 
further enhances the suitability of the system and methiod for a generic and expandable 
solution to data and metadata type conversions. 

Various embodiments may further include receiving or storing instructions and/or 
data implemented in accordance with the foregoing description upon a carrier medium. 
Suitable carrier media may include storage media or memory media such as magnetic or 
optical media, e.g., disk or CD-ROM, as well as transmission media or signals such as 
electrical, electromagnetic, or digital signals, conveyed via a communication medium 
such as network 108 and/or a wireless hnk. 

While the present invention has been described with reference to particular 
embodiments, it will be understood that the embodiments are illustrated and that the 
invention scope is not so limited. Any variations, modifications, additions and 
improvements to the embodiments described are possible. These variations, 
modifications, additions and improvements may fall within the scope of the invention as 
detailed within the following claims. 
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WHAT IS CLAIMED IS: 



1 . A method for mapping managed object metadata, the method comprising: 

5 inputting a first data type firom a first set of data types, wherein the first set of data 

types is expressed in an abstract syntax notation, and wherein the abstract 
syntax notation comprises a language for describing data; 

determining a corresponding second data type from a second set of data types, 
10 wherein the second set of data types is expressed in an interface definition 

language, wherein the interface definition language comprises a language 
for implementing interfaces to managed objects, wherein the interface 
definition language is operable across a plurality of platforms and across a 
plurality of programming languages, and wherein the interface definition 
15 language is class independent; and 

returning the second data type. 

2. The method of claim 1, wherein the managed object metadata comprises metadata 
20 concerning a telephone system. 

3. The method of claim 1, wherein the managed object metadata comprises metadata 
concerning a network switch. 

25 4. The method of claim 1, wherein the metadata comprises type information about 
an attribute of one of the managed objects. 

5. The method of claim 1, wherein the metadata comprises type information about 
an action of one of the managed objects. 

30 
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6. The method of claim 1, wherein the metadata comprises type information about a 
notification of one of the managed objects. 

7. The method of claim 1, wherein the first data tyi)e comprises a primitive data type 
5 in the abstract syntax notation, and wherein the second data type comprises a generic 

primitive data type in the interface definition language. 

8. The method of claim 1, wherein the first data t^np^ comprises an object data type 
in the abstract syntax notation, and wherein the second data type comprises a sequence of 

10 the generic primitive data type in the interface definition language. 

9. The method of claim 1, wherein the first data t)^e comprises an object data type 
in the abstract syntax notation, wherein the second data type comprises a choice structure 
of the interface definition language, and wherein the cho ice structure comprises: 

15 

a generic value field; 

a plurality of data types; and 

20 a selector, wherein the selector is an index whose value determines which of the 

plurality of data types is used to interpret the value in the generic value 
field. 

10. The method of claim 1, wherein the abstract syntax notation comprises Abstract 
25 Syntax Notation One. 

11. The method of claim 1, wherein the abstract syntax notation comprises Guidelines 
for Managed Objects (GDMO). 
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12. The method of claim 1, wherein the interface definition language is operable to 
provide a single mapping which is applicable to any managed object class. 

13. A method for mapping managed object metadata^ the method comprising: 

inputting a first data type from a first set of data types, wherein the first set of data 
types is expressed in an interface d(^fmition language, wherein the 
interface definition language comprise!? a language for implementing 
interfaces to managed objects, wherein the interface definition language is 
operable across a plurality of platfoims and across a plurality of 
programming languages, and wherein the interface definition language is 
operable to provide a single mapping which is applicable to any managed 
object class; 

determining a corresponding second data type from a second set of data types, 
wherein the second set of data types is expressed in an abstract syntax 
notation, and wherein the abstract syntax notation comprises a language 
for describing data; and 

returning the second data type. 

14. The method of claim 13, wherein the managed object metadata comprises 
metadata concerning a telephone system. 

15. The method of claim 13, wherein the managed object metadata comprises 
metadata conceming a network switch. 

16. The method of claim 13, wherein the metadata C'omprises type information about 
an attribute of one of the managed objects. 
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17. The method of claim 13^ wherein the metadata eomprises type information about 
an action of one of the managed objects. 

18. The method of claim 13, wherein the metadata c;omprises type information about 
5 a notification of one of the managed objects. 

19. The method of claim 13, wherein the first data tj^pe comprises a generic primitive 
data type in the interface definition language, and wherein the second data type comprises 
a primitive data type in the abstract syntax notation. 

10 

20. The method of claim 13, wherein the first data i^e comprises a sequence of the 
generic primitive data type in the interface definition hmguage, and wherein the second 
data type comprises an object data type in the abstract syntax notation. 

15 21. The method of claim 13, wherein the first data type comprises a choice structure 
of the interface definition language, wherein the choice structure comprises: 

a generic value field; 

20 a plurahty of data types; and 

a selector, wherein the selector is an index whose value determines which of the 
plurality of data types is used to interpret the value in the generic value 
field; and 

25 

wherein the second data type comprises an objec^t data type in the abstract syntax 
notation. 

22. The method of claim 13, wherein the abstract syntax notation comprises Abstract 
30 Syntax Notation One. 
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23. The method of claim 13, wherein the abstract syntax notation comprises 
Guidehnes for Managed Objects (GDMO). 

5 24. The method of claim 13, wherein the interface definition language is operable to 
provide a single mapping which is applicable to £iny managed object class. 

25. A computer system for mapping managed object metadata, wherein the system 
comprises: 

10 

a CPU; 

a memory coupled to the CPU, wherein the memory stores program instructions 
executable by the CPU, and wherein the program instructions are 
15 executable to: 

input a first data type from a first set of data types, wherein the first set of 
data types is expressed in an abstract syntax notation, and wherein 
the abstract syntax notation comjprises a language for describing 
20 object data; 

determine a corresponding second data type from a second set of data 
types, wherein the second set of data types is expressed in an 
interface definition language, \^^herein the interface definition 
25 language comprises a language for implementing interfaces to 

managed objects, wherein the interface definition language is 
operable across a plurality of platforms and across a plurality of 
programming languages, and v^^herein the data types in the 
interface definition language are cllass independent; and 
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return the second data type. 



26. The computer system of claim 25, wherein the managed object metadata 
comprises metadata concerning a telephone system. 

5 

27. The computer system of claim 25, wherein the managed object metadata 
comprises metadata concerning a network switch. 

28. The computer system of claim 25, wherein the abstract syntax notation comprises 
10 Abstract Syntax Notation One. 

29. The computer system of claim 25, wherein the alDstract syntax notation comprises 
Guidelines for Managed Objects (GDMO). 

15 30. The computer system of claim 25, wherein in determining the corresponding 
second data type from the second set of data types, the program instructions are 
executable to look up the second data type in one or more lookup tables. 

31. A carrier medium comprising program instructions for mapping managed object 
20 metadata, wherein the program instructions are computer-executable to implement: 

inputting a first data type from a first set of data types, wherein the first set of data 
types is expressed in an abstract syntax notation, and wherein the abstract 
syntax notation comprises a language for describing data; 

25 

determining a corresponding second data type from a second set of data types, 
wherein the second set of data types is expressed in an interface definition 
language, wherein the interface definition language comprises a language 
for implementing interfaces to managed objects, wherein the interface 
30 definition language is operable across a plurality of platforms and across a 
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plurality of programming languages, and wherein the interface definition 
language is class independent; and 

returning the second data type. 

5 

32. The carrier medium of claim 31, wherein the first data type comprises an object 
data type in the abstract syntax notation, and wherein the second data type comprises a 
sequence of the generic primitive data type in the interface definition language. 

10 33. A carrier medium comprising program instructions for mapping managed object 
metadata, wherein the program instructions are computer-executable to implement: 

inputting a first data type fi:-om a first set of data types, wherein the first set of data 
types is expressed in an interface definition language, wherein the 

15 interface definition language comprises a language for implementing 

interfaces to managed objects, wherein the interface definition language is 
operable across a plurality of platforms and across a plurality of 
programming languages, and wherein the interface definition language is 
operable to provide a single mapping which is applicable to any managed 

20 object class; 

determining a corresponding second data type from a second set of data types, 
wherein the second set of data types is expressed in an abstract syntax 
notation, and wherein the abstract synta?: notation comprises a language 
25 for describing data; and 

returning the second data type. 
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34. The carrier medium of claim 33, wherein the first data type comprises a sequence 
of the generic primitive data type in the interface definition language, and wherein the 
second data type comprises an object data type in the abstract syntax notation. 



Attorney Docket No.: 5181-46100 



Page 33 



Conley, Rose & Tayon, F.C. 



ABSTRACT OF THE DISCLOSURE 



A system and method for generic and dynamic mapping of managed object 
5 metadata. The data to be mapped may include type infonnation about an attribute, action, 
or notification of a managed object. The first data type may be entered into the mapping 
system, and then the corresponding second data type miay be determined. Finally, the 
second data type may be returned. In this manner, data types related to the attributes, 
events, or other parameters of managed objects may be converted between various data 
10 description languages, such as OMG IDL and ASNl. One of the data types may be 
represented in a generic interface description language which is operable to describe 
interfaces to managed objects across a plurality of platforms and across a plurality of 
programming languages. In addition, a single interface may be defined to describe 
substantially all data types and all managed objects. Having a single object interface for 
15 all TMN managed objects saves significant resources in that there is no need to statically 
compile and store separate interfaces for the many objects, which may increase the 
scalabihty of a network management system dramatically. One may also add a new 
object to the system without bringing the system dovm to compile a new interface, 
making it much easier to maintain system operations with httle or no downtime. 
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